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(54) Distributed directory services for locating network resources In a very large packet 
switching network 



(57) The present invention relates to a method and 
system of locating a network resource in a pacl^et 
switching network divkied In a backkx}ne subnetwork 
connected to one a a plurality of access subnetworks. 
TTie access subnetworks comprise one or a plurality of 
access border nodes directly connected to the back- 
bone subnetwork. The bacWDone subnetwork com- 
prises one or a plurality of backbone border nodes 
directly connected to the access subnetworks. Border 
nodes of different subnetworks are connected by border 
links. 

The method in access border nodes involves the 
steps of : 

receiving a query message comprising a resource 
name, the resource name including a prefix; 

• comparing the resource name prefix with the pre- 
fixes stored In an access border node directory 
database, sad access border node directory data- 
base comprising prefixes of the resources local to 
the access border node subnetwork; 

• determining whether the resource name relates to 
a resource which is k)cal to the access border node 
subnetwork or not; 

• forwarding said query message to an adjacent 
backtx)ne border node when the resource name 



relates to a resource which is not local to the 
access border node subnetwork 

The method in k>ackbone tx>rder nodes involves the 
steps of : 

• receiving a query message comprising a resource 
name, the resource name including a prefix; 

• comparing the resource name prefix with the pre- 
fixes stored in one or a plurality of backbone border 
node directory datat>ases. Each backtx>ne border 
node directory database corresponds to an access 
subnetwork managed by the backbone bader 
node; 

• determining whether the resource name relates to 
a resource which belongs to an access subnetwork 
that the backbone border node manages or not; 

• fbnwarding the query message to an adjacent 
access border node when the resource name 
relates to a resource which belongs to an access 
border node subnetwork managed by the backt)one 
border. 

Each access subnetwork has its own spanning tree 
and distributed topology, and interactions between 
access networks are limited to a minimum. The size of 
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distributed topologies is kept small and the control traffic 
is mostly limited to suk}networks. 
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Description 

Technical field of the invention 

[0001 ] The present invention relates to very large a s 
packet switching networks, wnti more particularly to a ^ 
method and system tor aeating and maintaining distrib- 
uted directory services in a network comprising a back- 
bone network connected to one or a plurality of access 
networks. 



nodes and the fundamental challenge for high speed 
networks is to minimize the processing time and to take 
full advantage of the high speed/low error rate technolo- 
gies, most of the transport and control functions pro- 
vided by the new high bandwidth netwak architectures 
are performed on an end to end basis. The flow control 
and particularly the path selection and bandwidth man- 
agement processes are managed by the access points 
of the network which reduces both the awareness and 
the function of the intermediate nodes. 
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Background art 

HIGH SPEED PACKET SWITCHING NETWORKS 

[0002] Data transmission is now evolving with a 
specific focus on applications and by integrating a fun- 
damental shift in the customer traffic profile. Driven by 
the growth of workstations, the local area networks 
interconnection, the distributed processing between 
workstations and super computers, the new applica- 
tions and the integration of various and often conflicting 
structures - hierarchk;al versus peer to peer, wide ver- 
sus local area networks, voice versus data - the data 
profile has become more bandwidth consuming, burst- 
ing, non<leterministic and requires more connectivity. 
Based on the above, there is strong requirement for 
supporting distributed computing applications across 
high speed networks that can carry local area network 
communications, voice, video and traffic among chan- 
nel attached hosts, business, engineering workstations, 
terminals, and small to intermediate file servers. This 
viston of a high speed multi-protocol network is the 
driver for the emergence of last packet switching net- 
works architectures In which data, voice, and video 
information is digitally encoded, chopped into small 
packets and transmitted through a common set of 
nodes and links. An efficient transport of mixed traffic 
streams on very high speed lines means for these new 
network architecture a set of requirements in term of 
performance and resource consumption which can be 
summarized as follows: 

• a very high throughput and a very short packet 
processing time. 

• a very large flexibility to support a wide range of 
connectivity options. 

• an efficient flow and congestion control. 

Throughput and Processing Time 

[0003] One of the key requirement of high speed 
packet switching networks is to reduce the end to end 
delay in order to satisfy real-time delivery constraints 
and to achieve the necessary high nodal throughput for 
the transport of voice and video. Increases in link 
speeds have not been matched by proportionate 
increases in the processing speeds of communication 



Connectivity 

[0004] In high speed networks, the nodes must pro- 
75 vide a total connectivity. This includes attachment of the 
user's devices, regardless of vendor or protocol, and the 
ability to have the end user communteated with any 
other device. The network must support any type of traf- 
fic including data* voice, video, fax. graphic or image. 
20 Nodes must be able to take advantage of all common 
carrier facilities and to be adaptable to a plurality of pro- 
tocols. All needed conversions must be automatic and 
transparent to the end user. 

25 Congestion and Row Control 

[0005] Communication networks have at their dis- 
posal limited resources to ensure an efficient packets 
transmission. An effk^lent bandwidth management is 

30 essential to take full advantage of a high speed network. 
While transmission costs per byte continue to drop year 
after year, transmission costs are likely to continue to 
represent the major expense of operating future tele- 
communication networks as the demand for bandwkith 

35 increases. Thus conskJerable efforts have been spent 
on designing ftow and congestion control processes, 
bandwidth reservation mechanisms, routing algorithms 
to manage the network bandwidth. An ideal network 
shoukj be able to transmit an useful traffic directly pro- 

40 portional to the traffic offered to the network and this as 
far as the maximum transmission capacity is reached. 
Beyond this limit, the network should operate at its max- 
imum capacity whatever the demand is. 

45 NETWORK CONTROL 

[0006] The ftow and congestion control operations 
generate additional traffic on the network. Ideally only 
the exact bandwidth needed at any time by a network 

so connection should be dynamically reserved for that con- 
nection, and also only the exact bandwkith needed for 
the network control operations shouto be resen/ed for 
that purpose. However, it is essential for an efficient flow 
and congestion control to provide at any time enough 

55 network resources in terms of bandwidth or perform- 
ance to the control traffic. The control traffic can be 
divided into two main families: 
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• a network signalling control traffic, and 

• a network routing control traffic. 

Signalling Control Traffic 

5 

[0007] The signalling control traffic is used to estab- 
lish point-to-point and point-to-multipoint network con- 
nections across the network Signalling control 
messages are generally forwarded towards the different 
nodes along the path of the connections. The signalling io 
control traffic includes: 

• Connection set-up and connection takedown mes- 
sages, 

Connections bandwidth refresh messages, is 

• Connections bandwkith adaptation 
(increase/decrease) messages, 

• Directory queries in network (directed to a specific 
resource), ... 

20 

Routing Control Traffic 

[0008] The routing control traffic is used for distrib- 
uting the network topology information between nodes 
of the network. This information is necessary mainly for 25 
the computation of routing paths between nodes in the 
network. Routing control messages are generally 
broadcasted to all nodes by means of Spanning Tree or 
flooding mechanisms. The routing control traffic 
includes: 30 

• Control Point Spanning Tree maintenance mes- 
sages, 

• Topology update messages 

• Directory searches in network (broadcast through 35 
the network), ... 

LARGE NETWORKS 

[0009] As shown in Rgure 6, large networks suffer 4o 
from tine large amount of control traffic necessary to 
update the distributed network topologies in view of the 
high number of nodes and transmission links. Directory 
queries are also an important contributor to the control 
traffic load. The problem is particularly sensible on 45 
spanning tree links and on links issued from access 
nodes. For optimizing tiie resources, in particular the 
bandwkith where it is the more demanded, several solu- 
tions have been conskJered. 

[0010] Most of tiie wide networks (large country, so 
world-wide networks) are configured so that a backtwne 
network can support the communications between dif- 
ferent access networks. Such network topology allows 
good performances and tiie optimisation of the network 
administration. Generally, access networks are private 55 
networks and indeed they are very often confined to a 
local area such as a building or a catrpus. However, a 
private network can be distributed over a wide area k>y 



the use of carrier links between nodes. The backbone 
network is generally a public network but can also be 
part of a private network using lines leased from a car- 
rier such as the PTT 

bandwidth Reservation for Control Traffic 

[0011] Because of tiie high importance of network 
traffic, enough bandwidtii on the links must be reserved 
to transmit the routing and signalling conti-ol messages. 
Insufficient resources for routing control messages 
could lead to invalid topology tables and a node, witii an 
erroneous or obsolete view of the network topology, 
may take wrong routing decisions. Insufficient 
resources for the signalling control messages coukJ 
also lead to en-ors or at least to a degradation of the 
quality of service in the establishment and management 
of network connections. US patent application no 
771333 (EP patent application no 95480178.3. IBM's 
reference FR9 95 017) entitied "Dynamic Bandwidtii 
Reservation for Control Traffic in High Speed Packet 
Switching Networks" discloses a metiiod and system for 
resenting dynamically and in priority for each link of the 
network tiie exact amount of bandwidth necessary for 
the transmission of the network conti'ol ti'aff ic. An evalu- 
ation of tiie expected control ti'affic on each link of tiie 
network is performed in order to allocate a sufficient but 
minimum fraction of tiie link bandwidtii and for allocating 
the maximum available bandwidth for the user traffic 

Hierarohlcal Networks 

[0012] Hierarchical netwaks have been proposed 
for a while, and such architectures are cun'entiy devel- 
oped for example with PNNI (Private Network to Net- 
work Interface) for ATM (Asynchronous Transfer Mode) 
networks or NBBS (Networking BroadBand Services) 
for IBM (Intemational Business Machine) networks. 

Private Network to Network hterface 

[0013] The Private Network to Network Interface 
(PNNI) is described in In the ATM Forum specifications 
(PNN1 1 .0 Specs March 1 996), however a summary can 
be found in publication entitled "Asynchronous Transfer 
Mode Networks - Performance Issues", second edition 
Artech House 1995 (Raif O. Onvural) incorporated 
herewith by reference, PNNI is the demarcation point 
between two switching systems. In this context, a 
switching system may be : 

• a single ATM switch. A PNNI is used between every 
pair of neighbour switches in the network. These 
switches may be built by different vendors. ATM end 
stations are attached to the network aaoss UNls 
(User to Network Interface). 

• alternatively, a collection of two or more ATM 
switches managed and operated under one admin- 
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istratlon. The network may be built with switches 
from a single vendor. This would eliminate the dis- 
advantages of operating at the level provided by the 
PNNI and allow it to take advantage of vendor spe- 
cific network services and solutions toward utilizing 
network resources efficiently. 

[0014] In the former case, the PNNI becomes a 
switch to switch interface, whereas in the later case, it is 
refened to as an network to network interface (NNI). 
PNNI includes the definitions of various physical inter- 
faces, ATM layer, management interface, and signalling. 
The ATM Forum PNNI specifk^ations Includes both rout- 
ing and signalling functions: 

PNNI routing comprises various "generic* network 
control functk)ns. such as call admission, path 
selection, and topology distribution. 
• PNNI signalling is used to cany PNNI routing 
related protocol information as well as perform call 
control functions for connection establishment 
management and termination. 

[0015] In PNNI routing, the switching system that a 
connection request originates from its UNI is responsi- 
ble for finding the end to end path to the destination end 
station. This is referred to as "source routing". For each 
connection request, the source switching finds a path 
based on the advertised capabilities and the desirability 
of other switching systems to can^y connections with dif- 
ferent characteristics. After finding the path, the origi- 
nating switching system uses PNNI signalling to request 
connection estat>lishment from intermediate switching 
systems along the path. PNNI routing is based on link 
state routing. Each switching system advertises a set of 
parameters including information about the links 
attached to it, quality of service parameters it can guar- 
antee, and its capability and desirability to carry particu- 
lar types of oonnectfons. Assuming that each switching 
system sends a message advertising the status of 
resources it controls as soon as a change takes place 
(i.e., upon accepting or terminating a connection). This 
message will arrive at other switching systems (at the 
minimum) after the corresponding propagation delays. 
Accordingly, source switching can never have up to date 
information about the status of other switching systems. 
Increasing the frequency and the amount of information 
advertised may be thought to enable "better" paths to 
be chosen. Doing so wouki also result in significant cost 
in bandwidth and processing complexity. At the other 
extreme, if no information is advertised then the 
chances of choosing "poor paths woukJ increase. The 
topology update mechanism in ATM networks needs to 
be designed with care. Otherwise, the cost of bandwidth 
and the processing complexity may not be justified 
when compared with the amount of network effciency 
achieved. 

The choice of what internal state information to adver- 
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tise. how often, and to where require the specification of 
a multilevel hierarchical routing model. The PNNI hierar- 
chical model is recursive and at each level of hierarchy, 
the topology is represented by logical nodes and logical 

5 links. At the lowest level of hierarchy, each node repre- 
sents a real switching system or a group of switching 
system. At higher layers, each node may represent 
either a real system or a group of switching systems. 
Similarly, PNNI links may conespond to either a real 

w physrcal link or a virtual link 

Nodes are collected into peer groups. All the nodes 
within a peer group exchange link information and 
obtain an identical topology database representing the 
peer group. Peers groups are organized into a hierarchy 

75 in which one or more peer groups are associated with a 
parent peer group. Parent peer groups are grouped into 
higher layer peer groups. 

The operation of PNNI routing in a parent group 
attempts to collapse a chiU peer group into a single 

20 node. In this case, there wouki be different paths to 
aoss a peer group, each with different characteristics. 
Hence, it is not always possible to advertise the true 
cost of the real physical paths. The representation of 
peer groups and their interconnections as fogical nodes 

25 and logical links implies that information distritxjted at 
higher layers is summarized. This allows the routing to 
scale to very large networks. Its consequence is tiiat 
somewhat imperfect paths may be selected. 
[0016] To summarize, the PNNI routing uses the 

30 concept of abstractfon. Nodes and links not pertaining 
to tiie local peer group do not appear as such but are 
factored in a topology summary. The summarized topol- 
ogy is built of a much smaller number of nodes and 
links. While the amount of control traff k: is proportional 

3S to the topology size, the corresponding control traffic i<x 
distributing the topology is reduced accordingly The 
drawt>ack is tiie complexity and imperfection introduced 
by the hierarchy. 

40 Spanning Tree 

[0017] The NBBS (Networking BroadBand Serv- 
ices) spanning tree function supports tiie routing control 
traffk; by interconnecting once every node in the net- 

45 work by means of a logical tree. Each node on the span- 
ning tree maintains a parent-child relationship with its 
adjacent node. At any one time, one of the nodes is the 
root of the spanning tree and this node coordinates tiie 
construction and maintenance of the tree. When the 

50 topology of the network changes because a node or link 
is activated or deactivated, a new root will be dynami- 
cally selected. Assuming an edge is a link that is part of 
ttie spanning tree, although every node in ttie network is 
in tiie spanning tree, only the minimum number of 

55 edges is used in order to connect the nodes. The main 
reason for using a spanning tree is that it allows infor- 
mation that has to go to every node to be sent very 
quickly and effidentiy. Every node receives a single 
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copy of every message (compared to many copies In 
the case of broadcast technology). However the span- 
ning tree maintenance cannot cope easily very large 
network (several hundreds of nodes) or unstat)le net- 
works which request frequent rearrangements or recon- 
necttons. 

[0018] More details concerning NBBS and more 
particularly the NBBS spanning tree can be found In the 
following publications : 

• "Networking BroadBand Services (NBBS), Archi- 
tecture Tutorial", IBM International Technical Sup- 
port Centers GG24-4486-00 June 1995. 

• "Communication-C^timal Maintenance of Dynamic 
Trees" by Baruch Awerbuch et al, 1/25/90 research 
report. 

• "Multicast Group Membership Management in High 
Speed Wide Area Networks" Auerbach et al. Inter- 
national Conference on Distributed Computing Sys- 
tems, Arlington , Texas. May 20-24. 1991, Institute 
of Electrical and Electronics Engineers, pages 231 
-238. 

• IBM Technical Disclosure Bulletin "Distributed Tree 
Maintenance" by et Cidon al. Vol. 35 No. 1 A. pages 
93-98. June 1992, RA891044. 

• European patent application 93480060.8 entitled 
"Multicast Communication Tree Creation and Con- 
trol Method and Apparatus" Auerbach et al (priority 
date 18/06/92). 

Decon^sl^on ofNetmrk Topology 

[0019] In the real world , large transport networks 
are not fully meshed. Networks are usually built around 
a hierarchical structure. A set of nodes interconnected 
by high throughput links are used to buikJ a "backbone" 
with a high degree of meshing to allow the redundancy 
and reliability required by the user. Then local nodes are 
grouped in geographical "subnetworks" themselves 
attached to the backbone. The control traffk; can take 
advantage of the particular network topology to drasti- 
cally reduce the network load. For a given connection, 
only a limited number of nodes are defined as eligible 
and are taken in account by the routing algorithm in the 
optimal route search. 

[0020] US patent 5.495,479 (EP application 
number 93480105.1 . IBM's reference FR 9 93 013 enti- 
tled "Method and Apparatus for an Automatic Decompo- 
sition of a Network Topology into a Backbone and 
Subareas" (C. Galand et al.) discloses a method and 
system for performing an automata decomposition of a 
networic into a backkx)ne and subareas to speed up the 
path selection process without degrading the optimiza- 
tion criterion of the routing algorithm and without gener- 
ating additional control messages on the network. The 
selection of a routing path in an access node involves 
the steps of storing the network configuration; automat- 
ically pre-selecting a set of usable links for each desti- 



nation node located in the network; storing locally said 
pre-selection of usable links; determining, for each con- 
nection request between said access node and a desti- 
nation node, a routing path among said pre-selected 
5 usable links. 

Objects of the invention 

[0021] The object of the present invention is to 
10 locate a network resource in a very large network 
divided in multiple subnetworks. 
[0022] It is a further object to limit in large networks 
the control traffic and in particular, topology update 
messages, control point spanning tree maintenance 
15 messages ... 

It is another object not to overload the network with mul- 
tiple directory queries. 

[0023] It is a another object to linrA the size of the 
network topology that a node can access to the subnet- 
20 work it belongs to. 

[0024] It is another object to define a simple and 
effective method and system for locating a resource in 
large networks. 

25 Summary of tiie invention 

[0025] The present invention relates to a method 
and system of locating a network resource In a packet 
switching netwak divided in a backbone subnetwork 

30 connected to one or a plurality of access subnetworks. 
The access subnetworks comprise one or a plurality of 
access border nodes directly connected to the back- 
bone subnetwork. The backt>one subnetwork com- 
prises one or a plurality of backbone border nodes 

35 directly connected to the access subnetworks. Border 
nodes of different subnetwori^ are connected by border 
links. 

[0026] The method in access border nodes involves 
the steps of: 

40 

• receiving a query message comprising a resource 
name, the resource name including a prefix; 

comparing the resource name prefix with the pre- 
45 fixes stored in an access border node directory 
datak)ase, said access border node directory data- 
base comprising prefixes of the resources local to 
the access border node subnetwork; 

so • determining whether the resource name relates to 
a resource which is local to the access border node 
subnetwork or not; 

• fonwarding said query message to an adjacent 
55 backbone border node when the resource name 

relates to a resource which is not local to the 
access bader node subnetwork. 
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[0027] The method In backbone border nodes 
involves the steps of: 

• receiving a query message comprising a resource 
name, the resource name including a prefix; 

• comparing the resource name prefix with the pre- 
fixes stored in one or a plurality of backbone border 
node directory databases. Each backbone border 
node directory database corresponds to an access 
subnetwork managed by the backbone border 
node: 

• determining whether the resource name relates to 
a resource which belongs to an access subnetwork 
that the backtx)ne border node manages or not; 

• fonwarding the query message to an adjacent 
access border node when the resource name 
relates to a resource which belongs to an access 
t>order node subnetwork managed by the backbone 
border. 

10028] Each access subnetwork has its own span- 
ning tree and distributed topology, and interactions 
between access networks are limited to a minimum. 
The size of distributed topologies is kept small and the 
control traffic is mostly limited to sub networks. 

Drawings 

[0029] The novel and inventive features believed 
characteristics of the invention are set forth in the 
appended clainris. The invention itself, however, as well 
as a preferred mode of use, further objects and advan- 
tages thereof will best be understood by reference to the 
following detailed description of an illustrative detailed 
embodiment when read in conjunction with the accom- 
panying drawings, wherein: 

• Figure 1 shows the bandwidth used by the control 
traffic in function of the number of nodes within the 
network. 

• Figure 2 shows a typk^ speed packet switching 
network. 

• Figure 3 describes a high speed routing point. 

• Figure 4 shows two users establishing a cotrvnuni- 
cation over a packet switching network. 

• Figure 5 desalbes the Topology DataBase struc- 
ture. 

• Figure 6 shows the distribution of the topology in a 
network comprising a bacMtx)ne subnetwork con- 
nected to a plurality of access subnetworks accord- 
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ing to the present invention. . 

Figure 7 shows the Directory Services Proxies 
according to the present invention. 

5 

^ • Rgure 8 is a flow chart of the broadcasting mecha- 
nism according to the present invention. 

Figure 9 is a flow chart of the procedure called 
10 when the Directory Services Proxy located in the 
access network receives a request message 
according to the present invention. 

Figure 10 is a flow chart of the procedure called 
15 when the Directory Services Proxy in the backtxxie 
network receives a request message ^cording to 
the present invention. 

• Figure 11 is a flow chart of process for initializing 
20 the link bridge and the associated Directory Serv- 
ices Proxies according to the present Invention. 

Preferred embodiment of ttte invention 

25 I PRIOR ART 

HIGH SPEED COMMUNICATIONS 

[0030] As illustrated in Figure 2, a typical model of 

30 communication system is made of several user net- 
works (212) communicating through a high perform- 
ance network (200) using private lines, carrier provided 
services, or public data networks. Each user network 
can be described as a set of communication processors 

35 and links (211) interconnecting large computers used 
as enterprise senders (213), user groups using worksta- 
tions or personal computers attached on l^N (Local 
Area Networks 214). applications senders (215). PBX 
(Private Branch exchange 216) or video servers (217). 

40 These user networks, spread in different establish- 
ments, need to be interconnected through wide area 
transport facilities and different approaches can be 
used for organizing the data transfer. Some architec- 
tures involve the checking for data integrity at each net- 

45 work node, thus slowing down the transmission. Others 
are essentially looking for a high speed data transfer. To 
that end the transmission, routing and switching tech- 
niques within the nodes are optimized to process the 
flowing packets toward their final destination at the high- 

50 est possible rate. The present invention belongs essen- 
tially to the latter category and more particularly to the 
fast packet switching network architecture detailed in 
the following paragraphs. 

55 High Performance Packet Switching Networks 

[0031] The general view in Figure 2 shows a fast 
packet switching transmission system comprising eight 
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nodes (201 to 208) each node being interconnected by 
means of high speed communication lines called Trunks 
(209). The access (210) to the high speed network by 
the users is realized through Access Nodes (202 to 205) 
located at the periphery. These Access Nodes comprise 5 
one or more Ports, each one providing an access point 
for attaching external devices supporting standard inter- 
faces to the network and performing the conversions 
required to transport the users data flow across the net- 
work from and to other external devices. As example, w 
the Access Node (202) interfaces respectively a Private 
Branch exchange (PBX). an application server and a 
hub through three Ports and communicates through the 
network by means of the adjacent Transit Nodes (201), 
(205) and (208). 15 

Switching Nodes 

[0032] Each network node (201 to 208) includes a 
Routing Point where the incoming data packets are 20 
selectively routed on the outgoing Trunks towards the 
neighbouring Transit Nodes. Such routing decisions are 
made according to the information contained In the 
header of the data packets. In addition to the basic 
packet routing function, the network nodes provide 25 
ancillary services such as: 

• the determinatfon of routing paths for packets origi- 
nated in the node, 

• directory services like retrieving and updating infor- 30 
mation about network users and resources. 

• the maintaining of a consistent view of the physical 
network topology, including link utilization informa- 
tion, and 

• the reservation of resources at access points of the 35 
network. 

[0033] These ancillary services include: 

• the storage witNn the node of alternate paths, 40 

• the updating of these paths. 

[0034] Each Port is connected to a plurality of user 
processing equipment, each user equipment compris- 
ing either a source of digital data to be transmitted to 4s 
another user system, or a data sink for consuming dig- 
ital data received from another user system, or. typically, 
both. The interpretation of the users protocols, the 
translation of the users data into packets formatted 
appropriately for their transmission on the packet net- so 
work (200) and the generation of a header to route 
these packets are executed by an Access Agent running 
in the Port. This header is made of Control. Routing and 
Redundancy Check Fields. 

55 

• The Routing Fields contain all the information nec- 
essary to route the packet through the network 
(200) to the destinatfon node to which it is 
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addressed. These fietis can take several formats 
depending on the routing mode specified (connec- 
tion oriented or connectionless routing mode...). 

• The Control Relds include, among other things, an 
encoded identification of the protocol to be used for 

^ interpreting the Routing FieWs. 

• The Redundancy Check Fiekis are used to check 
for enras in the header itself. If an error is detected, 
the packet Is discaided. 

Routing Points 

[0035] Figure 3 shows a general block diagram of a 
typical Routing Point (300) such as it can be found in the 
network nodes (201 to 208) illustrated in Figure 2. A 
Routing Point comprises a high speed packet Switch 
(302) onto which packets arriving at the Routing Point 
are entered. Such packets are received: 

• from other nodes over high speed transmission 
links (303) via Trunk Adapters (304). 

• from users via application adapters called Ports 
(301). 

[0036] Using information in the packet header, the 
adapters (304, 301) determine which packets are to be 
routed by means of the Switch (302) towards a local 
user network (307) or towards a transmission link (303) 
leaving the node. The adapters (301 and 304) include 
queuing circuits for queuing packets prior to or subse- 
quent to their launch on the Switch (302). 
[0037] The Route Controller (305) calculates the 
optimum paths through the network (200) so as to sat- 
isfy a given set of quality-of-services specified by the 
user and to minimize the amount of network resources 
used to complete the communication path. Then, it 
builds the header of the packets generated in the Rout- 
ing Point. The optimization criterion includes the 
number of intermediates nodes, tiie characteristics of 
the connection request, tiie capabilities and tiie utilisa- 
tion of tiie links (Trunks) in the path, tiie number of inter- 
mediate nodes... The optimum route is stored in a 
Routing Database (308) for further reuse. 
[0038] Ail tiie information necessary for tiie routing, 
about the nodes and transmission links connected to 
the nodes, are contained in a Network Topology Data- 
base (306). Under steady state condition, every Routing 
Point has tiie same view of tiie netwak. The network 
topology information is updated when new links are acti- 
vated, new nodes added to the network, when links or 
nodes are dropped or when link foads change signifi- 
cantly. Such information is exchanged by means of con- 
trol messages witti all other Route Controllers to provide 
the up-to-date topological information needed for path 
selection (such database updates are carried on pack- 
ets very similar to the data packets exchanged between 
end users of the network). The fact tiiat the network 
topology is kept current in every node through continu- 
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ous updates allows dynamic network reconfigurations 
without disrupting end users logical connections (ses- 
sions). 

[0039] The incoming transmission links to the 
packet Routing Point may comprise links from external 
devices in the local user networks (2 1 0) or links (Trunks) 
from adjacent netwak nodes (209). In any case, the 
Routing Point operates in the same manner to receive 
each data packet and fonA/ard it on to another Routing 
Point is dictated by the inlbmiation in the packet header. 
The fast packet switching network operates to enable a 
communication between any two end user applications 
without dedicating any transmission or node facilities to 
that communication path except for the duration of a sin- 
gle packet In this way. the utilisation of the communica- 
tion facilities of the packet network is optimized to carry 
significantly more traffic than would be possible with 
dedicated transmission links for each communication 
path. 

NETWORK MANAGEMENT 

Network Control Functions 

[0040] The Network Control Functions are those 
that control allocate, and manage the resources of the 
physical network. Each Routing Point has a set of the 
foregoing functions in the Route Controller (305) and 
uses it to facilitate the establishment and the mainte- 
nance of the connections between users applicatfons. 
The Network Control Functions include in particular: 

• Directory Services 

• for retrieving and maintaining information about 
network users and resources. 
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link^node failures. 

• Topology Update 

5 • for distributing and maintaining, using the 
Spanning Tree, information about the logical 
and physical network (including link utilization 
information) in every node. 

10 • Congestion Control 

• for enforcing the bandwidth reservation agree- 
ments between the network's users and the 
network which are established at the call set up 

15 time, and 

• for estimating actual bandwidth and for adjust- 
ing reservation if necessary during the life of 
the connection. 

20 TOPOLOGY DATABASE (TDB) 

[0041] The Topology Datat>ase contains informa- 
tion about nodes, links, their properties, and the band- 
width allocation. The topology information is replicated 
25 in each node of the network. An algorithm guarantees 
the correctness of each node's Topology Database 
when links and nodes are added or deleted or when 
their characteristics change. The database comprises: 

30 • the physical topology of the network which includes 
static information like physical characteristics of 
nodes and links, 

• the state of nodes and links, and 

• the link utilisation which includes dynamic charac- 
35 teristics like current bandwkith (used and 

reserved), real-time measurements... 



Bandwidth IManagement 

• for processing the bandwkith resen^tion and 
maintenance messages, and 

• for monitoring the current reservation levels on 
links. 

Path Selection 

• for choosing the best path for each new con- 
nection considering the connection require- 
ments and the current link utilisation levels. 

Control Spanning Tree 



40 



45 



50 



[0042] The general organisation of the Topology 
Database is shown in Figure 5. To each resource in the 
network, nodes (501) or links (502), is associated an 
entry in the datat)ase. In particular, each link entry 
includes the following characteristics: 

• (503) the link physical properties : 



transmission medium and speed, 

routing mode supported, 

maximum packet size, 

link buffer capacity, 

propagation delay, 

bandwkjth resen/ation supported... 



• for establishing and maintaining a routing tree 
among the network nodes, 

for using it to distribute control information (in 55 
parallel) including link utilisation, and 

• for updating the Topology Database of the 
nodes with new network configurations or 



(504) the link state: 

• on-line (link can accept user connections). 

• quiescent (link cannot accept additional user 

• connections, but existing connections con- 
tinue). 
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off-line (link cannot accept user connections 
and existing connections are cancelled)... 

• (505) the link utilization: 

• real-time measurements. 

• reserved bandwidth,... 

[0043] The Topology maintenance consists of 
advertizing and gathering the updates that occur inside 
the network Changes can be of three types : 

• The first type deals with link physical properties : 
additional linK link removal, reconfiguration ... 

• The second type deals with link state. 

• The third type deals with dynamic link utization. 

[0044] The concept of distrbuted topology 
assiffnes that each Control Point has the same view of 
the netwak. 

DIRECTPRY SERVICES 

[0045] The Directory Services are responsible for 
locating users in the network. Users are connected to 
external networks, which attach into the network via 
access agents located in access nodes. The Directory 
Services function is distributed around alt the directory 
agents which resKle In access agents. They are used on 
behalf of users when network connections are being 
established. 

Users of the Network 

[0046] A user is Mentified unk^uely kiy its "resource 
name**, which desaibes the user in its native protocol. 
The access agent in the access node communteates 
with users using their native protocols and names, but 
uses the particular network protocols and names when 
communicating with other network nodes. Directory 
Services is responsible for the mapping of a resource 
name into a partk^ular network name. The user's 
resource name is specified using the following three 
value : 

• Resource Identifier Type : this describes the 
addressing scheme used for this user (E.164, 
X.121.NSAR...). 

• Resource Identifier : this identifies a user within the 
syntax of the network described by the resource 
kientifier type. 

• Resource Identifier Prefix : The prefix is used to 
group together users of the same resource identi- 
fier type. The prefix is optional and used when 
directory services implements directory sets. 
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Directory Database 

[0047] Directory services uses a distributed direc- 
tory database. Each directory agent maintains its own 

5 local directory database which contains information 
^about users of the network. A local directory database 
has records for a subset of all the users of the network. 
Coni>ining all the local directory databases from the 
directory agents woukl give a complete view of the dis- 

10 tributed directory database. This is different from the 
Topology Services with its fully replicated Topology 
Database that gives every node a complete view of the 
network's topology. A k)cal directory database agent is 
managed by each directay agent. A node will have mul- 

15 tiple local directory database if there are multiple 
access agent on the node. From a view point of direc- 
tory services on a node, there are two sorts of users: 

Lxfcal user : local users are those which gain 
20 access to the network through this directory agent. 

• Remote users : renwte users are those which gain 
access to the network through a different directory 
agent 

25 [0048] The directory database contains a number 
of directory entries. An entry is present for each local 
user. There are also entries for some of the renrx)te 
users. The information which is kept in a directory entry 
includes among other parameters : 

30 

• resource identifier and prefix; 

• resource identifier type; 

• network addresses of the resource's access agent 
components (directory agent, protocol agent, con- 

35 nection agent); 

• etc.. 

[0049] Figure 4 shows two users who are establish- 
ing a communication in a network. It is assumed that 

40 User 1 (who is connected to node X), is setting up conn- 
munication with User 2 (connected to node Y). Directory 
sendees on node X happens to have a cache entry for 
User 2 as a result of a previous query. Hcw&/er, just 
knowing the external name (the resource name) is not 

45 enough to calculate a path across the network. The 
information about the access agent addresses is 
required because this is how a remote user is located 
and his network connection established. 
[0050] Information in the local directory database 

so can come from different sources : 

• Home entry : entries for local or remote users are 
generated In the local node using configuration 
Information provkJed by the customer. 

55 • Registered entry : information about local users 
can be provkJed using signalling as a result of an 
external search. 

• Cached entry : remote users are located as a result 
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of distributed queries (searches), and the infbrma- subnetwork to another although tNs Is not a restric- 

tion cached. tion. 



Distributed Queries 

5 

[0051] Directory services always Inspects the local ^ 
directory database for a target user. 

• If the target user is a local user, then a distributed 
query is not required. io 

• If a directory agent needs to inspect another part of 
the distributed directory database, a distributed 
query is used in order to locate a target user. 

[0052] The distributed queries are so called is 
because It is a search which is distributed among a 
group of remote directory agents. Distributed queries 
are sent from an origin directory agent to one or more 
destination directory agents, using either a directory set 
(a directory set is a group of directory agents which sup- 20 
port users with the same bngest matching address pre- 
fix) or the spanning tree. 

Undirected Explicit Queries 

25 

[0053] This type of query is used if the local direc- 
tory database doe not contain any information about the 
user to k}e located. TTie origin directory agent multicasts 
the query to the appropriate directory group using a 
default distribution tree (a default distribution tree is a 30 
tree which spans all the members of a particular direc- 
tory set). A remote directory agent will only reply to this 
type of query if it provides access to the destination 
user. A positive reply means that the destination user is 
a local member of the directory database of the destina- 
tion directory agent. When a directory agent replies 
positively to a query, it will provide the location of the tar- 
get user, in terms of the addresses of its access agent 
components. 

II PRESENT INVENTION 

NETWORK STRUCTURE 

[0054] The networi^ according to the present inven- 
tion, is partitioned into two types of subnetworks. The 
topology distribution is effective at the subnetwork level 
only 

• Access subnetworks have a limited number of 
nodes and links. These nodes are basically used 
for accessing the network as source nodes or des- 
tination nodes. 

• The backbone subnetwork is urnque and generally 
comprises a higher number of nodes and links than 
access subnetworks. The backbone subnetwork is 
mostly used for transmitting traffic from an access 



[0055] Consequently, nodes are not functionally 
specialized even if they belong to different types of sub- 
network. Access subnetworks may have direct links in 
between but an access siibnetworic should not be used 
for transmitting traffk; from an access node to another. 
An access subnetwori^ and the backtx)ne subnetwork 
may be connected by several links. 

• A node that belongs to an access subnetwork and 
that is directly connected to the backtx)ne subnet- 
work is called ^'access border node". 

• A node that belongs to the backbone subnetwork 
and that is directly connected to an access subnet- 
woric is called "backbone border node". 

• A link between border nodes of different subnet- 
works is called "border linl^. 

[0056] Figure 6 shows a typical network comprising 
a backbone subnetwork interconnected to a plurality of 
access subnetworks (access subnetworks 1 , 2, 3) : 

Nodes A, B. C M are interconnected with trans- 
mission links. 

• The backbone subnetwork comprises nodes D. E. 
F.G. 

• Access sulxietwork 1 is built of nodes A, B, C. 
Access subnetwork 2 is built of nodes I. J, H. 
Access subnetwork 3 is built of nodes K, U M- 

• Nodes B, C, K, U H. I are access border nodes. 
Nodes D, E, F, G are backbone border nodes. 

• Unks C-E, B-D. K-D, L-G. I-G. H-F, L-l are bader 
links. 

[0057] A node is identified by means of a subnet- 
work identifier and a node identifier, this node identifier 
is unique within the subnetwori< the node belongs ta A 
specific identifier is used to identify the backlx)ne sub- 
network. In each subnetwork (access or backbone) the 
associated topology content is shown in a TDB pattern. 

TOPOLOGY DATABASE fTDB) 

[0058] Each node within a same subnetwork has 
tfie same view of the subnetwork topology The informa- 
tion contained in tiie Topology DataBase (TDB) is lim- 
ited to the subnetwork level and to adjacent border 
nodes : there is no systemafic replication between sub- 
networks. As described previously entries in the Topol- 
ogy DataBase are of two types : node or link. There is 
one node entry for each subnetwork node (nodes A. B, 
C) and each adjacent border node (nodes E. D). There 
is one link entry for each unidirectional link. Each unidi- 
rectional link being attached to its origin node, the sub- 
network Topology DataBase (TDB) contains all the 
unidirectional links attached to tiie subnetwork nodes. 
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This includes the unidirectional border links of the sub- 
network border nodes (C ->E, B->D). 
As shown in Figure 6, the different Topology DataBases 
(TOB) are exclusive. However, they partially share each 
other the knowledge of the backbone subnetwork or the 
knowledge of the adjacent access subnetworks (adja- 
cent border nodes and border links). For instance, the 
Topology DataBase of access subnetwork l comprises 
all the nodes (A. B, C) located within this subnetwork, 
the corresponding outgoing unidirectional links (A -> B, 
A->C.B->A. B->C. B->D.C->A,C->B,C->E)and 
the backbone border nodes (D, E). Unidirectional border 
links (B -> D, C -> E) of access border nodes (B. C) are 
included. 

[0059] In the present invention, local subnetwork 
Topology DataBases are neither dpplicated nor con- 
catenated. They are used locally : 

• for innplementing: 

in each access subnetworK an access subnet- 
work Directay Services Proxy in an access 
border node and 
• in the backbone subnetwork, a backbone sub- 
network Directory Services Proxy in backbone 
border nodes. 

• for defining a unique link brkige for each access 
subnetwork. 

DIRECTORY SERVICES 

[0060] The locating of network resources is neces- 
sary in order to set up a network connection between a 
source and a destination. As detailed prevk}usly. a 
resource is uniquely identified by a resource name 
which usually follows an addressing scheme. E164. 
NSAP for example. It is assumed that the addressing 
scheme is structured so that, in most case, a prefix can 
be extracted and the relation to a given subnetwork be 
assigned. In small networks, the resource search can 
be simply an undirected query message broadcasted to 
every node. On the contrary, in large network it is not 
possible to broadcast every query message without 
overloading the network. The network partitioning into 
access subnetworks and backbone subnetwork gives 
the opportunity to improve the efficiency of the broad- 
casting mechanism while remaining unchanged the 
existing search mechanism in nodes. 

Link Bridge 

[0061] Several links may interconnect an access 
subnetwork and the backbone subnetwork. In order to 
avokj duplication of undirected searches outside the 
originating subnetwork, a unique link is selected to 
become a "link bridge" between two border nodes of dif- 
ferent types: access subnetwork border node and back- 
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bone subnetwork border node. There is a single link 
brktge per access subnetwork. 

Directory Services Proxies 

5 

40062] In border nodes (access border node and 
backbone border node) of each subnetwork bridge link, 
a Directory Services Proxy is Implemented : 

10 • The purpose of an access subnetwork Directory 
Services Proxy is to determine whether an undi- 
rected query message relates to a resource that is 
local to the subnetwori< or a resource that belongs 
to another subnetwork. The undirected query mes- 

75 sage Is either discarded or forwarded accordingly 

• The purpose of a backbone subnetwori^ Directory 
Services Proxy is to determine whetiier a query 
message relates to a resource that belongs to a 

20 subnetwork it manages or not. 

[0063] Figures 7 and 8 are showing an undirected 
query issued from an access subnetwork 

25 Broadcasting Mechanism 

[0064] 

• 801 : Source node A - A query message with a 
30 resource name (or address) is sent by the Directory 

Services of source node A preferably using the 
services of the source subnetwork spanning tree, 

• 802 : Border node B - This query message is inter- 
ns cepted and read by the Directory Services Proxy 

located in access border node B. This Directory 
Services Proxy determines whether this query 
message relates to a local resource or not. Query 
message with a non local resource name (resource 
40 name - "0492115952" for instance - that doesn't 
match any access subnetwork 1 resource identifier 
prefix in the directory database of node B) are for- 
warded to the backtxxie subnetwork. Query mes- 
sages with a local resource name are fonvarded 
45 along the subnetwork spanning tree. 

Note : in a preferred embodiment, query mes- 
sages are forwarded to the t>ackbone subnetwork in 
Remote Access to Label-Swap Tree transfer mode 
which is a combination of the ANR (Automatic Net- 
so work Routing) and label swapping transfer modes. 
The remote access to label-swap tree transfer 
mode uses AN R to transfer a packet for the first part 
of its journey and then uses label swapping for the 
remainder of the journey. The remote access to 
55 Label-Swap tree is used because packets may be 
replicated at some transit nodes and each repli- 
cated packet sent to a different destination with a 
different label. 
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803 : Backbone border node D - Node D has its 
own directory database but has also access to the 
directory database of the access subnetwork Direc- 
tory Services Proxies of the access subnetworks it 
manages. At reception of the query message, node 
D determines whether it is targeted to an access 
subnetwork it manages (access subnetwork 3) or 
not Because in our example, node D does not rec- 
ognize in the query message a resource identifier 
prefix that corresponds to the access subnetwork it 
manages, it fonwards the query message to the next 
node (node G) on the backbone subnetwork span- 
ning tree. Node G forward in its turn the query mes- 
sage to node F. 
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804 : Node F - Node F recognizes that the resource 
name corresponds to an access subnetwork that It 
manages (the address "04921 U" matches the 
resource identifier prefix of access subnetwork 2). It 
fooAards the query message to this access subnet- 20 
work via the link bridge (F->H). 

805 : Node H - The access border node H multi- 
casts on the subnetwork spanning tree the query 
message within the access subnetwork 2. 2s 



806 : Node J • Node J receives the multicasted 
query message as any node in the access subnet- 
work 2. recognizes the ownership of the resource 
and prepares a response. This response is sent 
directly to the requester (node A) thanks to the 
Reverse Path Accumulation function. 



[0065] Note : The Reverse Path Accumulation func- 
tion enables the path that a packet has traversed 
through the network to be recorded in the header of the 
packet This can then be used by the recipient of the 
packet to effk^iently construct a reply packet. 

Proxy in Access Subnetworks 

[0066] Figure 9 shows the procedure that is called 
when a Directory Services Proxy in an access subnet- 
work receives a query message : 

• 900 : the procedure is triggered at reception of a 
request message. 

• 901 : a test determines whether or not the resource 
name of the target resource matches a proxy direc- 
tory datat}ase entry (resource identifier prefix 
stored in the directory database of the access bor- 
der node). 

• H the resource name matches an entry of the 
proxy directory database (a resource identifier 
prefix), the procedure goes on with step (902) 

• If the resource name does not match any entry 
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of the proxy directory. database (a resource 
identifier prefix), the procedure goes on with 
step (903) 

• 902 : the resource name of the target has been 
found, therefore the request is fonvarded to the next 
node on the access subnetwork spanning tree and 
the procedure terminates on step (904). 

• 903 : the resource name of the target has not been 
found, therefore the request is forwarded on the link 
bridge to the Directory Services Proxy located in 
the border node of the backbone subnetwork. Tlie 
procedure terminates on step 904. 

Proxy in Backbone Subnetwork 

[0067] Rgure 1 0 shows the procedure that is called 
when a Directory Services Proxy in a backbone subnet- 
work receives a query message : 

• 1000 : the procedure is triggered at reception of a 
request message. 

• 1001 : a test determines whether or not the 
resource name of the target resource matches a 
proxy directory database entry (resource identifier 
prefix stored in the directory database of the back- 
bone border node). 

• If the resource name matches an entry in the 

proxy directory database (resource identifier 
prefix), the procedure goes on with step (1003) 

If the resource name does not match any entry 
in the proxy directory database (a resource 
identifier prefix), the procedure goes on with 
step (1002) 

• 1002 : the resource name of the target has not been 
found, therefore the request is fonwarded to the next 
node on the backbone subnetwork spanning tree 
and the procedure terminates on step (1004). 
1003 : the resource name of the target has been 
found, therefore the request is fonA/arded on the link 
bridge to the Directory Sen/ices Proxy located in 
the border node of the access subnetwork. The pro- 
cedure terminates on step (1004). 

Link bridge 

[0068] The selection of a link brkJge between a 
backbone and an access border node Is the responsibil- 
ity of the access subnetwork. A simple criterion based 
on the access subnetwork topology allows the selection 
of a unk]ue link bridge since the Topology DataBase is 
the same for each node within a given access subnet- 
works. The node at the origin of the link candidate for 
being the link bridge calls an initialization procedure for 
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setting up the Directory Services Proxies in both access 
and baddxxie border nodes. 
[0069] The Figure 11 shows the selection process 
of a link bridge between nodes B and D and the initiali- 
zation of the caresponding Directory Services Proxies 
(access and backbone proxies). 

• 11 01 : Node (A) having the responsibility for select- 
ing a link bridge sends a message to all subnetwork 
nodes informing them that link B-D has been 
selected. At reception of this message, all subnet- 
work nodes send to node (B) at the origin of that 
link the set of the resource identifier prefixes they 
manage. 

• 1102 : Node (B) initializes the access subnetwork 
Directory Services Proxy with the resource identi- 
fier prefixes of all subnetwork nodes and adds its 
own prefixes. Then, it sends to the backbone border 
node (D) a request with all the resource identifier 
prefixes known in the access subnetwork for initial- 
izing the backbone subnetwork Directory Sen^ices 
Proxy. 

• 1103 : Node (D) initializes the backbone subnet- 
work Directory Services Proxy and stores the 
received resource identifier prefixes. Then, it sends 
a reply to the access node (B). 

• 1104 : Node (B) returns an acknowledgement to 
node (A) to confirm the link bridge set-up. 

[0070] The backbone side is passive but keeps a 
liveness with the access side to confirm the backbone 
proxy existence on behalf of this access subnetwork. 
Any topology change inside the access subnetwork can 
Invalidate the link bridge and restart another initializa- 
tion process. 

Spanning Tree 

[0071 ] The network is no more managed by a single 
spanning tree but by as many spanning trees as subnet- 
works (access subnetworks plus backfcxxie subnet- 
work). Each subnetwork maintains its own spanning 
tree independently. The advantage is obviously the flex- 
ibility, the fast response time plus the capacity to rear- 
range a subnetwork without impacting the whole 
network. The spanning tree algorithm checks the sub- 
network identifier of every node that can be reached 
and limit the set-up to those pertaining to the same 
access network. To provide a complete connectivity to 
Directory Services Proxies, a link (bridge link) is 
selected automatically between each access subnet- 
work and the bacMx)ne network. The access subnet- 
work is responsible of selecting this link. The border 
nodes on the selected link automatically activate the 
Directory Services Proxy functions. 
[0072] While the invention has been particularly 
shown and desaibed with reference to a preferred 
embodiment, it will be understood that varfous changes 



in form and detail may be made therein without depart- 
ing from the spirit, and scope of the inventfon. 

Claims 

5 

J. A method in an access border node of locating a 
network resource in a packet switching network 
divkied in a backbone subnetwork connected to 
one or a plurality of access subnetworks, said net- 

10 work comprising a plurality of nodes interconnected 
with transmission links, said access subnetworks 
comprising one or a plurality of access border 
nodes directly connected to the backbone subnet- 
work, said backtxxie subnetwork comprising one or 

75 a plurality of backtx^ne border nodes directly con- 
nected to the access subnetworks, border nodes of 
different subnetworks being connected by border 
links, said method involving the steps of: 



receiving (900) a query message conprising a 
resource name, said resource name including 
a prefix; 

• comparing (901) sakl resource name prefix 
with the prefixes stored in an access border 
node directory database, said access bader 
node directory database comprising prefixes of 
the resources local to tiie access border node 
subnetwork; 

• determining (901) whether tiie resource name 
relates to a resource which is local to the 
access border node subnetwork or not; 

• fonwarding (903) said query message to an 
adjacent backbone border node when said 
resource name relates to a resource which is 
not local to the access border node subnet- 
work. 

2. The method according to the preceding claim, com- 
prising the further step of : 

• multicasting (902) said query message within 
the access kx>fder node subnetwork when said 
resource name relates to a resource local to 
said access border node subnetwork. 

3. The method according to the preceding daim 
wherein step of multicasting said query message 
comprises the step of fonvarding said query mes- 
sage along a local spanning tree defined within tiie 
access bader node subnetwork. 



55 4. The metiiod according to any one of ttie preceding 
claims conprising the step of: 

• receiving (1101) from other nodes in tiie 
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access border ncxie subnetwork, the prefixes 
of the resources they manage: 

adding the prefixes of the resources the access 
border node nnanage locally: s 



initializing (1102) the access border node 
directory database with the prefixes of the 
resources local to the access txvder node sub- 
network. 



5. The method according to the preceding claim com- 
prising the further step of: 

• fbnwarding (1102) to the adjacent backbone 
border node a copy of the access border node 
directory database. 

6. A method in a backbone border node of locating a 
network resource in a packet switching network 
divided in a backbone subnetwork connected to 
one or a plurality of access subnetworks, said net- 
work comprising a plurality of nodes interconnected 
with transmission links, said access subnetworks 
comprising one or a plurality of access kx)rder 
nodes directly connected to the backbone subnet- 
work, said backbone subnetwork comprising one or 
a plurality of backbone tx)rder nodes directly con- 
nected to the access subnetworks, border nodes of 
different subnetworks being connected by border 
links, sakJ method involving the steps of : 

• receiving (1000) a query message comprising 
a resource name, said resource name includ- 
ing a prefix; 

• comparing (1001) said resource name prefix 
with the prefixes stored in one or a plurality of 
backbone border node directory databases, 
each backbone border node directory data- 
base con^esponding to an access subnetwork 
managed by the t)ackt>one border node: 

• determining (1001) whether the resource name 
relates to a resource which belongs to an 
access subnetwork that the backbone border 
node manages or not: 

• fonwarding (1003) said query message to an 
adjacent access border node when said 
resource name relates to a resource which 
belongs to an access border node subnetwork 
managed by the backbone border. 

7. The method according to the preceding claim com- 
prising the further step of : 



10 



15 



20 



2S 



30 



35 



the backbone subnetwork when said resource 
name relates to a resource which does not 
belong to any of the access border node sub- 
networks managed by the backbone border 
node. 

8. The method according to the preceding claim 
wherein sakil step of multk^asting said query mes- 
sage comprises the step of forwarding said query 
message along a local spanning tree defined within 
the backbone suk>network. 

9. TTie method according to any one of claims 6 to 8 
connprising the further steps of: 

• receiving from each subnetwork managed by 
the backtx)ne border node, a access border 
node directory database. 

• Initializing (1103) the backbone border node 
directory databases with the received access 
k)order node directory databases. 

10. The method according to any one of the preceding 
wherein within each access subnetworK there is 
one and only one access border node with an 
access border node directory datat>ase connected 
to a backbone subnetwork, border node comprising 
one or a plurality of backbone border node directory 
databases. 

11. The method according to any one of the preceding 
claims wherein each node has access to a topology 
of the subnetwork it belongs to. 



12. The method according to any one of the preceding 
claims wherein the topology of each subnetwork 
comprises information concerning the subnetwork 
nodes and subnetwork links and information con- 

40 earning the adjacent border nodes and border links. 

13. TTie method according to any one of the preceding 

claims wherein said access subnetworks may have 
direct links in between but an access subnetwork 
45 should not be used for transmitting traffic from an 
access node to another. 

14. An access border node for carrying out the method 
according to any one of claims 1 to 5 and 10 to 13. 

50 

15. A backbone border node for carrying out the 
method according to any one of claims 6 to 13. 

16. A network comprising nodes according ot any one 
55 of claims 14 to 15. 



multicasting ((1 002) said query message within 
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